package com.szholly.plug.cms.entity.content;

import java.util.HashMap;

import org.springframework.stereotype.Component;

import com.szholly.utils.spring.SpringBeanFactory;
import com.szholly.data.general.*;
import com.szholly.data.general.metadata.IBaseTable;

/**
 * 内容的访问数
 */
@Component("cms_content_count")
public class ContentCountTable extends InterceptorTableBase  implements IBaseTable{

	public final static String TABLE_NAME = "cms_content_count";
	
	/**
	 * single ref
	 */
	public static ContentCountTable getSingleRef() {
		return (ContentCountTable) SpringBeanFactory.getBean("cms_content_count");
	}

	@Override
	public String getMetadataTableName() {
		return TABLE_NAME;
	}

	@Override
	public String getMetadataTableAliasName() {
		return "内容的访问数";
	}

	private HashMap<String, Field> fields;

	@Override
	protected HashMap<String, Field> fields() {
		if (fields == null) {
			fields = new HashMap<String, Field>();

			Field itemField = new Field();
			itemField.setFieldName(RowBase.FIELD_GUID);
			itemField.setDataType(GlobalDataType.String);
			itemField.setFieldID(1);
			itemField.setFieldAliasName("GUID");
			itemField.setCanShow(false);
			fields.put(itemField.getFieldName().toUpperCase().trim(), itemField);
			
			itemField = new Field();
			itemField.setFieldName(RowBase.FIELD_VERSION);
			itemField.setDataType(GlobalDataType.Int32);
			itemField.setFieldID(2);
			itemField.setFieldAliasName("VERSION");
			fields.put(itemField.getFieldName().toUpperCase().trim(), itemField);
			
			itemField = new Field();
			itemField.setFieldName(RowBase.FIELD_COMPANY);
			itemField.setDataType(GlobalDataType.String);
			itemField.setFieldID(3);
			itemField.setFieldAliasName("COMPANY");
			itemField.setCanShow(false);
			fields.put(itemField.getFieldName().toUpperCase().trim(), itemField);
			
			itemField = new Field();
			itemField.setFieldName(RowBase.FIELD_SYSTEMNAME);
			itemField.setDataType(GlobalDataType.String);
			itemField.setFieldID(4);
			itemField.setFieldAliasName("SYSTEMNAME");
			itemField.setCanShow(false);
			fields.put(itemField.getFieldName().toUpperCase().trim(), itemField);
			
			itemField = new Field();
			itemField.setFieldName(ContentCountRow.FIELD_Views);
			itemField.setDataType(GlobalDataType.Int32);
			itemField.setFieldID(4);
			itemField.setFieldAliasName("总访问数");
			itemField.setCanShow(false);
			fields.put(itemField.getFieldName().toUpperCase().trim(), itemField);
			
			itemField = new Field();
			itemField.setFieldName(ContentCountRow.FIELD_Downloads);
			itemField.setDataType(GlobalDataType.Int32);
			itemField.setFieldID(4);
			itemField.setFieldAliasName("总下载数");
			itemField.setCanShow(false);
			fields.put(itemField.getFieldName().toUpperCase().trim(), itemField);
			
			itemField = new Field();
			itemField.setFieldName(ContentCountRow.FIELD_ViewsWeek);
			itemField.setDataType(GlobalDataType.Int32);
			itemField.setFieldID(4);
			itemField.setFieldAliasName("周访问数");
			itemField.setCanShow(false);
			fields.put(itemField.getFieldName().toUpperCase().trim(), itemField);
			
			itemField = new Field();
			itemField.setFieldName(ContentCountRow.FIELD_DownloadsDay);
			itemField.setDataType(GlobalDataType.Int32);
			itemField.setFieldID(4);
			itemField.setFieldAliasName("日下载数");
			itemField.setCanShow(false);
			fields.put(itemField.getFieldName().toUpperCase().trim(), itemField);
			
			itemField = new Field();
			itemField.setFieldName(ContentCountRow.FIELD_ContentId);
			itemField.setDataType(GlobalDataType.Int32);
			itemField.setFieldID(4);
			itemField.setFieldAliasName("content_id");
			itemField.setCanShow(false);
			fields.put(itemField.getFieldName().toUpperCase().trim(), itemField);
			
			itemField = new Field();
			itemField.setFieldName(ContentCountRow.FIELD_DownloadsWeek);
			itemField.setDataType(GlobalDataType.Int32);
			itemField.setFieldID(4);
			itemField.setFieldAliasName("周下载数");
			itemField.setCanShow(false);
			fields.put(itemField.getFieldName().toUpperCase().trim(), itemField);
			
			itemField = new Field();
			itemField.setFieldName(ContentCountRow.FIELD_Comments);
			itemField.setDataType(GlobalDataType.Int32);
			itemField.setFieldID(4);
			itemField.setFieldAliasName("总评论数");
			itemField.setCanShow(false);
			fields.put(itemField.getFieldName().toUpperCase().trim(), itemField);
			
			itemField = new Field();
			itemField.setFieldName(ContentCountRow.FIELD_ViewsDay);
			itemField.setDataType(GlobalDataType.Int32);
			itemField.setFieldID(4);
			itemField.setFieldAliasName("日访问数");
			itemField.setCanShow(false);
			fields.put(itemField.getFieldName().toUpperCase().trim(), itemField);
			
			itemField = new Field();
			itemField.setFieldName(ContentCountRow.FIELD_CommentsDay);
			itemField.setDataType(GlobalDataType.Int32);
			itemField.setFieldID(4);
			itemField.setFieldAliasName("日评论数");
			itemField.setCanShow(false);
			fields.put(itemField.getFieldName().toUpperCase().trim(), itemField);
			
			itemField = new Field();
			itemField.setFieldName(ContentCountRow.FIELD_UpsWeek);
			itemField.setDataType(GlobalDataType.Int32);
			itemField.setFieldID(4);
			itemField.setFieldAliasName("周顶数");
			itemField.setCanShow(false);
			fields.put(itemField.getFieldName().toUpperCase().trim(), itemField);
			
			itemField = new Field();
			itemField.setFieldName(ContentCountRow.FIELD_Ups);
			itemField.setDataType(GlobalDataType.Int32);
			itemField.setFieldID(4);
			itemField.setFieldAliasName("总顶数");
			itemField.setCanShow(false);
			fields.put(itemField.getFieldName().toUpperCase().trim(), itemField);
			
			itemField = new Field();
			itemField.setFieldName(ContentCountRow.FIELD_ViewsMonth);
			itemField.setDataType(GlobalDataType.Int32);
			itemField.setFieldID(4);
			itemField.setFieldAliasName("月访问数");
			itemField.setCanShow(false);
			fields.put(itemField.getFieldName().toUpperCase().trim(), itemField);
			
			itemField = new Field();
			itemField.setFieldName(ContentCountRow.FIELD_CommentsWeek);
			itemField.setDataType(GlobalDataType.Int32);
			itemField.setFieldID(4);
			itemField.setFieldAliasName("周评论数");
			itemField.setCanShow(false);
			fields.put(itemField.getFieldName().toUpperCase().trim(), itemField);
			
			itemField = new Field();
			itemField.setFieldName(ContentCountRow.FIELD_UpsMonth);
			itemField.setDataType(GlobalDataType.Int32);
			itemField.setFieldID(4);
			itemField.setFieldAliasName("月顶数");
			itemField.setCanShow(false);
			fields.put(itemField.getFieldName().toUpperCase().trim(), itemField);
			
			itemField = new Field();
			itemField.setFieldName(ContentCountRow.FIELD_Downs);
			itemField.setDataType(GlobalDataType.Int32);
			itemField.setFieldID(4);
			itemField.setFieldAliasName("总踩数");
			itemField.setCanShow(false);
			fields.put(itemField.getFieldName().toUpperCase().trim(), itemField);
			
			itemField = new Field();
			itemField.setFieldName(ContentCountRow.FIELD_CommentsMonth);
			itemField.setDataType(GlobalDataType.Int32);
			itemField.setFieldID(4);
			itemField.setFieldAliasName("月评论数");
			itemField.setCanShow(false);
			fields.put(itemField.getFieldName().toUpperCase().trim(), itemField);
			
			itemField = new Field();
			itemField.setFieldName(ContentCountRow.FIELD_DownloadsMonth);
			itemField.setDataType(GlobalDataType.Int32);
			itemField.setFieldID(4);
			itemField.setFieldAliasName("月下载数");
			itemField.setCanShow(false);
			fields.put(itemField.getFieldName().toUpperCase().trim(), itemField);
			
			itemField = new Field();
			itemField.setFieldName(ContentCountRow.FIELD_UpsDay);
			itemField.setDataType(GlobalDataType.Int32);
			itemField.setFieldID(4);
			itemField.setFieldAliasName("日顶数");
			itemField.setCanShow(false);
			fields.put(itemField.getFieldName().toUpperCase().trim(), itemField);
			
		}
		return fields;
	}

	@Override
	public String getTableGroup() {
		return "CMS";
	}
}